package com.crdeng.system.mapper;

import com.crdeng.system.entity.Role;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * <p>
 * 角色表 Mapper 接口
 * </p>
 *
 * @author crdeng
 * @since 2020-11-27
 */

@Mapper
public interface RoleMapper extends BaseMapper<Role> {

    /*查询用户以拥有的权限*/
    List<Integer> getRoleListByUserId(Long id);

    /**
     * 在角色和用户中间表添加数据
     * @param id
     * @param roleId
     */
    void  saveRole_User(@Param("id") Long id ,@Param("roleId") Integer roleId);

    /**
     * 根据用户ID删除中间表的权限
     * @param id 用户ID
     */
    void deleteRole_User(Long id);

    /**
     * 查询所有角色的ID
     * @return
     */
    List<Integer> getRoleId();

    /**
     * 根据用户ID查询所有角色名
     * @param id
     * @return
     */
    List<String> getRoleNameByUserId(Long id);


    /**
     * 查询角色已拥有的菜单权限
     * @param id
     * @return
     */
    List<Integer> getMenuId(Integer id);

    void saveRole_Menu(@Param("id") Integer id,@Param("menuId") Integer menuId);

    /**
     * 根据角色ID删除中间表的数据
     * @param id
     */
    void deleteRole_Menu(Integer id);
}
